styleproperties: Move into deprecated directory
authorBenjamin Otte <otte@redhat.com>
Fri, 24 Oct 2014 19:31:15 +0000 (21:31 +0200)
committerBenjamin Otte <otte@redhat.com>
Fri, 24 Oct 2014 19:31:40 +0000 (21:31 +0200)
12 files changed:
gtk/Makefile.am
gtk/deprecated/gtkgradient.h
gtk/deprecated/gtkstyleproperties.c [new file with mode: 0644]
gtk/deprecated/gtkstyleproperties.h [new file with mode: 0644]
gtk/deprecated/gtkstylepropertiesprivate.h [new file with mode: 0644]
gtk/deprecated/gtksymboliccolor.h
gtk/deprecated/gtkthemingengine.h
gtk/gtk.h
gtk/gtkstyleproperties.c [deleted file]
gtk/gtkstyleproperties.h [deleted file]
gtk/gtkstylepropertiesprivate.h [deleted file]
gtk/gtkstyleprovider.h

index b840f1600bfaa00e6e2c394ebf644416481aa992..f60bec87a7f3c91aaab13113c4ea6fedfacd6a53 100644 (file)
@@ -239,6 +239,7 @@ deprecated_h_sources =                      \
        deprecated/gtkstatusicon.h      \
        deprecated/gtkstock.h           \
        deprecated/gtkstyle.h           \
+       deprecated/gtkstyleproperties.h \
        deprecated/gtksymboliccolor.h   \
        deprecated/gtktable.h           \
        deprecated/gtktearoffmenuitem.h \
@@ -271,6 +272,7 @@ a11y_private_h_sources =                    \
 deprecated_private_h_sources =                 \
        deprecated/gtkgradientprivate.h         \
        deprecated/gtknumerableiconprivate.h    \
+       deprecated/gtkstylepropertiesprivate.h  \
        deprecated/gtksymboliccolorprivate.h
 
 gtk_public_h_sources =                 \
@@ -443,7 +445,6 @@ gtk_public_h_sources =              \
        gtkstackswitcher.h      \
        gtkstatusbar.h          \
        gtkstylecontext.h       \
-       gtkstyleproperties.h    \
        gtkstyleprovider.h      \
        gtkswitch.h             \
        gtktestutils.h          \
@@ -655,7 +656,6 @@ gtk_private_h_sources =             \
        gtkstyleanimationprivate.h \
        gtkstylecascadeprivate.h \
        gtkstylecontextprivate.h \
-       gtkstylepropertiesprivate.h \
        gtkstylepropertyprivate.h \
        gtkstyleproviderprivate.h \
        gtktextbtree.h          \
@@ -768,6 +768,7 @@ deprecated_c_sources =                      \
        deprecated/gtkstatusicon.c      \
        deprecated/gtkstock.c           \
        deprecated/gtkstyle.c           \
+       deprecated/gtkstyleproperties.c \
        deprecated/gtksymboliccolor.c   \
        deprecated/gtktable.c           \
        deprecated/gtktearoffmenuitem.c \
@@ -1047,7 +1048,6 @@ gtk_base_c_sources =              \
        gtkstyleanimation.c     \
        gtkstylecascade.c       \
        gtkstylecontext.c       \
-       gtkstyleproperties.c    \
        gtkstyleproperty.c      \
        gtkstyleprovider.c      \
        gtkstyleproviderprivate.c       \
index 6eccb3bf239c4333e7ffe06970444970d58fe6de..e0d3e348caa74a448c29f87415d4696b8e4c2c64 100644 (file)
@@ -24,7 +24,7 @@
 
 #include <gdk/gdk.h>
 #include <gtk/gtkstylecontext.h>
-#include <gtk/gtkstyleproperties.h>
+#include <gtk/deprecated/gtkstyleproperties.h>
 #include <gtk/deprecated/gtksymboliccolor.h>
 
 G_BEGIN_DECLS
diff --git a/gtk/deprecated/gtkstyleproperties.c b/gtk/deprecated/gtkstyleproperties.c
new file mode 100644 (file)
index 0000000..f61f7a2
--- /dev/null
@@ -0,0 +1,956 @@
+/* GTK - The GIMP Toolkit
+ * Copyright (C) 2010 Carlos Garnacho <carlosg@gnome.org>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "config.h"
+
+#include "gtkstylepropertiesprivate.h"
+
+#include <stdlib.h>
+#include <gobject/gvaluecollector.h>
+#include <cairo-gobject.h>
+
+#include "gtkstyleprovider.h"
+#include "gtkcssshorthandpropertyprivate.h"
+#include "gtkcsstypedvalueprivate.h"
+#include "gtkcsstypesprivate.h"
+#include "gtkborderimageprivate.h"
+
+#include "gtkprivatetypebuiltins.h"
+#include "gtkstylepropertyprivate.h"
+#include "gtkstyleproviderprivate.h"
+#include "gtkintl.h"
+#include "gtkwin32themeprivate.h"
+
+#include "deprecated/gtkthemingengine.h"
+#include "deprecated/gtkgradient.h"
+#include "deprecated/gtksymboliccolorprivate.h"
+
+G_GNUC_BEGIN_IGNORE_DEPRECATIONS;
+
+/**
+ * SECTION:gtkstyleproperties
+ * @Short_description: Store for style property information
+ * @Title: GtkStyleProperties
+ *
+ * GtkStyleProperties provides the storage for style information
+ * that is used by #GtkStyleContext and other #GtkStyleProvider
+ * implementations.
+ *
+ * Before style properties can be stored in GtkStyleProperties, they
+ * must be registered with gtk_style_properties_register_property().
+ *
+ * Unless you are writing a #GtkStyleProvider implementation, you
+ * are unlikely to use this API directly, as gtk_style_context_get()
+ * and its variants are the preferred way to access styling information
+ * from widget implementations and theming engine implementations
+ * should use the APIs provided by #GtkThemingEngine instead.
+ *
+ * #GtkStyleProperties has been deprecated in GTK 3.16. The CSS
+ * machinery does not use it anymore and all users of this object
+ * have been deprecated.
+ */
+
+typedef struct PropertyData PropertyData;
+typedef struct ValueData ValueData;
+
+struct ValueData
+{
+  GtkStateFlags state;
+  GtkCssValue *value;
+};
+
+struct PropertyData
+{
+  GArray *values;
+};
+
+struct _GtkStylePropertiesPrivate
+{
+  GHashTable *color_map;
+  GHashTable *properties;
+};
+
+static void gtk_style_properties_provider_init         (GtkStyleProviderIface            *iface);
+static void gtk_style_properties_provider_private_init (GtkStyleProviderPrivateInterface *iface);
+static void gtk_style_properties_finalize              (GObject                          *object);
+
+
+G_DEFINE_TYPE_WITH_CODE (GtkStyleProperties, gtk_style_properties, G_TYPE_OBJECT,
+                         G_ADD_PRIVATE (GtkStyleProperties)
+                         G_IMPLEMENT_INTERFACE (GTK_TYPE_STYLE_PROVIDER,
+                                                gtk_style_properties_provider_init)
+                         G_IMPLEMENT_INTERFACE (GTK_TYPE_STYLE_PROVIDER_PRIVATE,
+                                                gtk_style_properties_provider_private_init));
+
+static void
+gtk_style_properties_class_init (GtkStylePropertiesClass *klass)
+{
+  GObjectClass *object_class = G_OBJECT_CLASS (klass);
+
+  object_class->finalize = gtk_style_properties_finalize;
+}
+
+static PropertyData *
+property_data_new (void)
+{
+  PropertyData *data;
+
+  data = g_slice_new0 (PropertyData);
+  data->values = g_array_new (FALSE, FALSE, sizeof (ValueData));
+
+  return data;
+}
+
+static void
+property_data_remove_values (PropertyData *data)
+{
+  guint i;
+
+  for (i = 0; i < data->values->len; i++)
+    {
+      ValueData *value_data;
+
+      value_data = &g_array_index (data->values, ValueData, i);
+
+      _gtk_css_value_unref (value_data->value);
+      value_data->value = NULL;
+    }
+
+  if (data->values->len > 0)
+    g_array_remove_range (data->values, 0, data->values->len);
+}
+
+static void
+property_data_free (PropertyData *data)
+{
+  property_data_remove_values (data);
+  g_array_free (data->values, TRUE);
+  g_slice_free (PropertyData, data);
+}
+
+static gboolean
+property_data_find_position (PropertyData  *data,
+                             GtkStateFlags  state,
+                             guint         *pos)
+{
+  gint min, max, mid;
+  gboolean found = FALSE;
+  guint position;
+
+  if (pos)
+    *pos = 0;
+
+  if (data->values->len == 0)
+    return FALSE;
+
+  /* Find position for the given state, or the position where
+   * it would be if not found, the array is ordered by the
+   * state flags.
+   */
+  min = 0;
+  max = data->values->len - 1;
+
+  do
+    {
+      ValueData *value_data;
+
+      mid = (min + max) / 2;
+      value_data = &g_array_index (data->values, ValueData, mid);
+
+      if (value_data->state == state)
+        {
+          found = TRUE;
+          position = mid;
+        }
+      else if (value_data->state < state)
+          position = min = mid + 1;
+      else
+        {
+          max = mid - 1;
+          position = mid;
+        }
+    }
+  while (!found && min <= max);
+
+  if (pos)
+    *pos = position;
+
+  return found;
+}
+
+static ValueData *
+property_data_get_value (PropertyData  *data,
+                         GtkStateFlags  state)
+{
+  guint pos;
+
+  if (!property_data_find_position (data, state, &pos))
+    {
+      ValueData new = { 0 };
+
+      new.state = state;
+      g_array_insert_val (data->values, pos, new);
+    }
+
+  return &g_array_index (data->values, ValueData, pos);
+}
+
+static GtkCssValue *
+property_data_match_state (PropertyData  *data,
+                           GtkStateFlags  state)
+{
+  guint pos;
+  gint i;
+
+  if (property_data_find_position (data, state, &pos))
+    {
+      ValueData *val_data;
+
+      /* Exact match */
+      val_data = &g_array_index (data->values, ValueData, pos);
+      return val_data->value;
+    }
+
+  if (pos >= data->values->len)
+    pos = data->values->len - 1;
+
+  /* No exact match, go downwards the list to find
+   * the closest match to the given state flags, as
+   * a side effect, there is an implicit precedence
+   * of higher flags over the smaller ones.
+   */
+  for (i = pos; i >= 0; i--)
+    {
+      ValueData *val_data;
+
+      val_data = &g_array_index (data->values, ValueData, i);
+
+       /* Check whether any of the requested
+        * flags are set, and no other flags are.
+        *
+        * Also, no flags acts as a wildcard, such
+        * value should be always in the first position
+        * in the array (if present) anyways.
+        */
+      if (val_data->state == 0 ||
+          ((val_data->state & state) != 0 &&
+           (val_data->state & ~state) == 0))
+        return val_data->value;
+    }
+
+  return NULL;
+}
+
+static void
+gtk_style_properties_init (GtkStyleProperties *props)
+{
+  props->priv = gtk_style_properties_get_instance_private (props);
+  props->priv->properties = g_hash_table_new_full (NULL, NULL, NULL,
+                                                   (GDestroyNotify) property_data_free);
+}
+
+static void
+gtk_style_properties_finalize (GObject *object)
+{
+  GtkStylePropertiesPrivate *priv;
+  GtkStyleProperties *props;
+
+  props = GTK_STYLE_PROPERTIES (object);
+  priv = props->priv;
+  g_hash_table_destroy (priv->properties);
+
+  if (priv->color_map)
+    g_hash_table_destroy (priv->color_map);
+
+  G_OBJECT_CLASS (gtk_style_properties_parent_class)->finalize (object);
+}
+
+static void
+gtk_style_properties_provider_init (GtkStyleProviderIface *iface)
+{
+}
+
+static GtkCssValue *
+gtk_style_properties_provider_get_color (GtkStyleProviderPrivate *provider,
+                                         const char              *name)
+{
+  GtkSymbolicColor *symbolic;
+
+  symbolic = gtk_style_properties_lookup_color (GTK_STYLE_PROPERTIES (provider), name);
+  if (symbolic == NULL)
+    return NULL;
+
+  return _gtk_symbolic_color_get_css_value (symbolic);
+}
+
+static void
+gtk_style_properties_provider_lookup (GtkStyleProviderPrivate *provider,
+                                      const GtkCssMatcher     *matcher,
+                                      GtkCssLookup            *lookup)
+{
+  GtkStyleProperties *props;
+  GtkStylePropertiesPrivate *priv;
+  GHashTableIter iter;
+  gpointer key, value;
+
+  props = GTK_STYLE_PROPERTIES (provider);
+  priv = props->priv;
+
+  /* Merge symbolic style properties */
+  g_hash_table_iter_init (&iter, priv->properties);
+
+  while (g_hash_table_iter_next (&iter, &key, &value))
+    {
+      GtkCssStyleProperty *prop = key;
+      PropertyData *data = value;
+      GtkCssValue *value;
+      guint id;
+
+      id = _gtk_css_style_property_get_id (prop);
+
+      if (!_gtk_css_lookup_is_missing (lookup, id))
+          continue;
+
+      value = property_data_match_state (data, _gtk_css_matcher_get_state (matcher));
+      if (value == NULL)
+        continue;
+
+      _gtk_css_lookup_set (lookup, id, NULL, value);
+    }
+}
+
+static GtkCssChange
+gtk_style_properties_provider_get_change (GtkStyleProviderPrivate *provider,
+                                          const GtkCssMatcher     *matcher)
+{
+  return GTK_CSS_CHANGE_STATE;
+}
+
+static void
+gtk_style_properties_provider_private_init (GtkStyleProviderPrivateInterface *iface)
+{
+  iface->get_color = gtk_style_properties_provider_get_color;
+  iface->lookup = gtk_style_properties_provider_lookup;
+  iface->get_change = gtk_style_properties_provider_get_change;
+}
+
+/* GtkStyleProperties methods */
+
+/**
+ * gtk_style_properties_new:
+ *
+ * Returns a newly created #GtkStyleProperties
+ *
+ * Returns: a new #GtkStyleProperties
+ *
+ * Deprecated: 3.16: #GtkStyleProperties are deprecated.
+ **/
+GtkStyleProperties *
+gtk_style_properties_new (void)
+{
+  return g_object_new (GTK_TYPE_STYLE_PROPERTIES, NULL);
+}
+
+/**
+ * gtk_style_properties_map_color:
+ * @props: a #GtkStyleProperties
+ * @name: color name
+ * @color: #GtkSymbolicColor to map @name to
+ *
+ * Maps @color so it can be referenced by @name. See
+ * gtk_style_properties_lookup_color()
+ *
+ * Since: 3.0
+ *
+ * Deprecated: 3.8: #GtkSymbolicColor is deprecated.
+ **/
+void
+gtk_style_properties_map_color (GtkStyleProperties *props,
+                                const gchar        *name,
+                                GtkSymbolicColor   *color)
+{
+  GtkStylePropertiesPrivate *priv;
+
+  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
+  g_return_if_fail (name != NULL);
+  g_return_if_fail (color != NULL);
+
+  priv = props->priv;
+
+  if (G_UNLIKELY (!priv->color_map))
+    priv->color_map = g_hash_table_new_full (g_str_hash,
+                                             g_str_equal,
+                                             (GDestroyNotify) g_free,
+                                             (GDestroyNotify) gtk_symbolic_color_unref);
+
+  g_hash_table_replace (priv->color_map,
+                        g_strdup (name),
+                        gtk_symbolic_color_ref (color));
+
+  _gtk_style_provider_private_changed (GTK_STYLE_PROVIDER_PRIVATE (props));
+}
+
+/**
+ * gtk_style_properties_lookup_color:
+ * @props: a #GtkStyleProperties
+ * @name: color name to lookup
+ *
+ * Returns the symbolic color that is mapped
+ * to @name.
+ *
+ * Returns: (transfer none): The mapped color
+ *
+ * Since: 3.0
+ *
+ * Deprecated: 3.8: #GtkSymbolicColor is deprecated.
+ **/
+GtkSymbolicColor *
+gtk_style_properties_lookup_color (GtkStyleProperties *props,
+                                   const gchar        *name)
+{
+  GtkStylePropertiesPrivate *priv;
+
+  g_return_val_if_fail (GTK_IS_STYLE_PROPERTIES (props), NULL);
+  g_return_val_if_fail (name != NULL, NULL);
+
+  priv = props->priv;
+
+  if (!priv->color_map)
+    return NULL;
+
+  return g_hash_table_lookup (priv->color_map, name);
+}
+
+void
+_gtk_style_properties_set_property_by_property (GtkStyleProperties  *props,
+                                                GtkCssStyleProperty *style_prop,
+                                                GtkStateFlags        state,
+                                                GtkCssValue         *value)
+{
+  GtkStylePropertiesPrivate *priv;
+  PropertyData *prop;
+  ValueData *val;
+
+  priv = props->priv;
+  prop = g_hash_table_lookup (priv->properties, style_prop);
+
+  if (!prop)
+    {
+      prop = property_data_new ();
+      g_hash_table_insert (priv->properties, (gpointer) style_prop, prop);
+    }
+
+  val = property_data_get_value (prop, state);
+
+  _gtk_css_value_unref (val->value);
+  val->value = _gtk_css_value_ref (value);
+
+  _gtk_style_provider_private_changed (GTK_STYLE_PROVIDER_PRIVATE (props));
+}
+
+/**
+ * gtk_style_properties_set_property:
+ * @props: a #GtkStyleProperties
+ * @property: styling property to set
+ * @state: state to set the value for
+ * @value: new value for the property
+ *
+ * Sets a styling property in @props.
+ *
+ * Since: 3.0
+ *
+ * Deprecated: 3.16: #GtkStyleProperties are deprecated.
+ **/
+void
+gtk_style_properties_set_property (GtkStyleProperties *props,
+                                   const gchar        *property,
+                                   GtkStateFlags       state,
+                                   const GValue       *value)
+{
+  GtkStyleProperty *node;
+
+  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
+  g_return_if_fail (property != NULL);
+  g_return_if_fail (value != NULL);
+
+  node = _gtk_style_property_lookup (property);
+
+  if (!node)
+    {
+      g_warning ("Style property \"%s\" is not registered", property);
+      return;
+    }
+  if (_gtk_style_property_get_value_type (node) == G_TYPE_NONE)
+    {
+      g_warning ("Style property \"%s\" is not settable", property);
+      return;
+    }
+  
+  _gtk_style_property_assign (node, props, state, value);
+}
+
+/**
+ * gtk_style_properties_set_valist:
+ * @props: a #GtkStyleProperties
+ * @state: state to set the values for
+ * @args: va_list of property name/value pairs, followed by %NULL
+ *
+ * Sets several style properties on @props.
+ *
+ * Since: 3.0
+ *
+ * Deprecated: 3.16: #GtkStyleProperties are deprecated.
+ **/
+void
+gtk_style_properties_set_valist (GtkStyleProperties *props,
+                                 GtkStateFlags       state,
+                                 va_list             args)
+{
+  const gchar *property_name;
+
+  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
+
+  property_name = va_arg (args, const gchar *);
+
+  while (property_name)
+    {
+      GtkStyleProperty *node;
+      gchar *error = NULL;
+      GType val_type;
+      GValue val = G_VALUE_INIT;
+
+      node = _gtk_style_property_lookup (property_name);
+
+      if (!node)
+        {
+          g_warning ("Style property \"%s\" is not registered", property_name);
+          break;
+        }
+
+      val_type = _gtk_style_property_get_value_type (node);
+      if (val_type == G_TYPE_NONE)
+        {
+          g_warning ("Style property \"%s\" is not settable", property_name);
+          break;
+        }
+
+      G_VALUE_COLLECT_INIT (&val, _gtk_style_property_get_value_type (node),
+                            args, 0, &error);
+      if (error)
+        {
+          g_warning ("Could not set style property \"%s\": %s", property_name, error);
+          g_value_unset (&val);
+          g_free (error);
+          break;
+        }
+
+      _gtk_style_property_assign (node, props, state, &val);
+      g_value_unset (&val);
+
+      property_name = va_arg (args, const gchar *);
+    }
+}
+
+/**
+ * gtk_style_properties_set:
+ * @props: a #GtkStyleProperties
+ * @state: state to set the values for
+ * @...: property name/value pairs, followed by %NULL
+ *
+ * Sets several style properties on @props.
+ *
+ * Since: 3.0
+ *
+ * Deprecated: 3.16: #GtkStyleProperties are deprecated.
+ **/
+void
+gtk_style_properties_set (GtkStyleProperties *props,
+                          GtkStateFlags       state,
+                          ...)
+{
+  va_list args;
+
+  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
+
+  va_start (args, state);
+  gtk_style_properties_set_valist (props, state, args);
+  va_end (args);
+}
+
+typedef struct {
+  GtkStyleProperties *props;
+  GtkStateFlags       state;
+} StyleQueryData;
+
+static GtkCssValue *
+style_query_func (guint    id,
+                  gpointer data)
+{
+  StyleQueryData *query = data;
+  PropertyData *prop;
+
+  prop = g_hash_table_lookup (query->props->priv->properties,
+                              _gtk_css_style_property_lookup_by_id (id));
+  if (prop == NULL)
+    return NULL;
+
+  return property_data_match_state (prop, query->state);
+}
+
+/**
+ * gtk_style_properties_get_property:
+ * @props: a #GtkStyleProperties
+ * @property: style property name
+ * @state: state to retrieve the property value for
+ * @value: (out) (transfer full):  return location for the style property value.
+ *
+ * Gets a style property from @props for the given state. When done with @value,
+ * g_value_unset() needs to be called to free any allocated memory.
+ *
+ * Returns: %TRUE if the property exists in @props, %FALSE otherwise
+ *
+ * Since: 3.0
+ *
+ * Deprecated: 3.16: #GtkStyleProperties are deprecated.
+ **/
+gboolean
+gtk_style_properties_get_property (GtkStyleProperties *props,
+                                   const gchar        *property,
+                                   GtkStateFlags       state,
+                                   GValue             *value)
+{
+  StyleQueryData query = { props, state };
+  GtkStyleProperty *node;
+
+  g_return_val_if_fail (GTK_IS_STYLE_PROPERTIES (props), FALSE);
+  g_return_val_if_fail (property != NULL, FALSE);
+  g_return_val_if_fail (value != NULL, FALSE);
+
+  node = _gtk_style_property_lookup (property);
+  if (!node)
+    {
+      g_warning ("Style property \"%s\" is not registered", property);
+      return FALSE;
+    }
+  if (_gtk_style_property_get_value_type (node) == G_TYPE_NONE)
+    {
+      g_warning ("Style property \"%s\" is not gettable", property);
+      return FALSE;
+    }
+
+  _gtk_style_property_query (node,
+                             value,
+                             style_query_func,
+                             &query);
+
+  return TRUE;
+}
+
+/**
+ * gtk_style_properties_get_valist:
+ * @props: a #GtkStyleProperties
+ * @state: state to retrieve the property values for
+ * @args: va_list of property name/return location pairs, followed by %NULL
+ *
+ * Retrieves several style property values from @props for a given state.
+ *
+ * Since: 3.0
+ *
+ * Deprecated: 3.16: #GtkStyleProperties are deprecated.
+ **/
+void
+gtk_style_properties_get_valist (GtkStyleProperties *props,
+                                 GtkStateFlags       state,
+                                 va_list             args)
+{
+  const gchar *property_name;
+
+  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
+
+  property_name = va_arg (args, const gchar *);
+
+  while (property_name)
+    {
+      gchar *error = NULL;
+      GValue value = G_VALUE_INIT;
+
+      if (!gtk_style_properties_get_property (props,
+                                             property_name,
+                                             state,
+                                             &value))
+       break;
+
+      G_VALUE_LCOPY (&value, args, 0, &error);
+      g_value_unset (&value);
+
+      if (error)
+        {
+          g_warning ("Could not get style property \"%s\": %s", property_name, error);
+          g_free (error);
+          break;
+        }
+
+      property_name = va_arg (args, const gchar *);
+    }
+}
+
+/**
+ * gtk_style_properties_get:
+ * @props: a #GtkStyleProperties
+ * @state: state to retrieve the property values for
+ * @...: property name /return value pairs, followed by %NULL
+ *
+ * Retrieves several style property values from @props for a
+ * given state.
+ *
+ * Since: 3.0
+ *
+ * Deprecated: 3.16: #GtkStyleProperties are deprecated.
+ **/
+void
+gtk_style_properties_get (GtkStyleProperties *props,
+                          GtkStateFlags       state,
+                          ...)
+{
+  va_list args;
+
+  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
+
+  va_start (args, state);
+  gtk_style_properties_get_valist (props, state, args);
+  va_end (args);
+}
+
+/**
+ * gtk_style_properties_unset_property:
+ * @props: a #GtkStyleProperties
+ * @property: property to unset
+ * @state: state to unset
+ *
+ * Unsets a style property in @props.
+ *
+ * Since: 3.0
+ *
+ * Deprecated: 3.16: #GtkStyleProperties are deprecated.
+ **/
+void
+gtk_style_properties_unset_property (GtkStyleProperties *props,
+                                     const gchar        *property,
+                                     GtkStateFlags       state)
+{
+  GtkStylePropertiesPrivate *priv;
+  GtkStyleProperty *node;
+  PropertyData *prop;
+  guint pos;
+
+  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
+  g_return_if_fail (property != NULL);
+
+  node = _gtk_style_property_lookup (property);
+
+  if (!node)
+    {
+      g_warning ("Style property \"%s\" is not registered", property);
+      return;
+    }
+  if (_gtk_style_property_get_value_type (node) == G_TYPE_NONE)
+    {
+      g_warning ("Style property \"%s\" is not settable", property);
+      return;
+    }
+
+  if (GTK_IS_CSS_SHORTHAND_PROPERTY (node))
+    {
+      GtkCssShorthandProperty *shorthand = GTK_CSS_SHORTHAND_PROPERTY (node);
+
+      for (pos = 0; pos < _gtk_css_shorthand_property_get_n_subproperties (shorthand); pos++)
+        {
+          GtkCssStyleProperty *sub = _gtk_css_shorthand_property_get_subproperty (shorthand, pos);
+          gtk_style_properties_unset_property (props,
+                                               _gtk_style_property_get_name (GTK_STYLE_PROPERTY (sub)),
+                                               state);
+        }
+      return;
+    }
+
+  priv = props->priv;
+  prop = g_hash_table_lookup (priv->properties, node);
+
+  if (!prop)
+    return;
+
+  if (property_data_find_position (prop, state, &pos))
+    {
+      ValueData *data;
+
+      data = &g_array_index (prop->values, ValueData, pos);
+
+      _gtk_css_value_unref (data->value);
+      data->value = NULL;
+
+      g_array_remove_index (prop->values, pos);
+
+      _gtk_style_provider_private_changed (GTK_STYLE_PROVIDER_PRIVATE (props));
+    }
+}
+
+/**
+ * gtk_style_properties_clear:
+ * @props: a #GtkStyleProperties
+ *
+ * Clears all style information from @props.
+ *
+ * Deprecated: 3.16: #GtkStyleProperties are deprecated.
+ **/
+void
+gtk_style_properties_clear (GtkStyleProperties *props)
+{
+  GtkStylePropertiesPrivate *priv;
+
+  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
+
+  priv = props->priv;
+  g_hash_table_remove_all (priv->properties);
+
+  _gtk_style_provider_private_changed (GTK_STYLE_PROVIDER_PRIVATE (props));
+}
+
+/**
+ * gtk_style_properties_merge:
+ * @props: a #GtkStyleProperties
+ * @props_to_merge: a second #GtkStyleProperties
+ * @replace: whether to replace values or not
+ *
+ * Merges into @props all the style information contained
+ * in @props_to_merge. If @replace is %TRUE, the values
+ * will be overwritten, if it is %FALSE, the older values
+ * will prevail.
+ *
+ * Since: 3.0
+ *
+ * Deprecated: 3.16: #GtkStyleProperties are deprecated.
+ **/
+void
+gtk_style_properties_merge (GtkStyleProperties       *props,
+                            const GtkStyleProperties *props_to_merge,
+                            gboolean                  replace)
+{
+  GtkStylePropertiesPrivate *priv, *priv_to_merge;
+  GHashTableIter iter;
+  gpointer key, value;
+
+  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
+  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props_to_merge));
+
+  priv = props->priv;
+  priv_to_merge = props_to_merge->priv;
+
+  /* Merge symbolic color map */
+  if (priv_to_merge->color_map)
+    {
+      g_hash_table_iter_init (&iter, priv_to_merge->color_map);
+
+      while (g_hash_table_iter_next (&iter, &key, &value))
+        {
+          const gchar *name;
+          GtkSymbolicColor *color;
+
+          name = key;
+          color = value;
+
+          if (!replace &&
+              g_hash_table_lookup (priv->color_map, name))
+            continue;
+
+          gtk_style_properties_map_color (props, name, color);
+        }
+    }
+
+  /* Merge symbolic style properties */
+  g_hash_table_iter_init (&iter, priv_to_merge->properties);
+
+  while (g_hash_table_iter_next (&iter, &key, &value))
+    {
+      PropertyData *prop_to_merge = value;
+      PropertyData *prop;
+      guint i;
+
+      prop = g_hash_table_lookup (priv->properties, key);
+
+      if (!prop)
+        {
+          prop = property_data_new ();
+          g_hash_table_insert (priv->properties, key, prop);
+        }
+
+      for (i = 0; i < prop_to_merge->values->len; i++)
+        {
+          ValueData *data;
+          ValueData *value;
+
+          data = &g_array_index (prop_to_merge->values, ValueData, i);
+
+          if (replace && data->state == GTK_STATE_FLAG_NORMAL &&
+              _gtk_is_css_typed_value_of_type (data->value, PANGO_TYPE_FONT_DESCRIPTION))
+            {
+              /* Let normal state override all states
+               * previously set in the original set
+               */
+              property_data_remove_values (prop);
+            }
+
+          value = property_data_get_value (prop, data->state);
+
+          if (_gtk_is_css_typed_value_of_type (data->value, PANGO_TYPE_FONT_DESCRIPTION) &&
+              value->value != NULL)
+            {
+              PangoFontDescription *font_desc;
+              PangoFontDescription *font_desc_to_merge;
+
+              /* Handle merging of font descriptions */
+              font_desc = g_value_get_boxed (_gtk_css_typed_value_get (value->value));
+              font_desc_to_merge = g_value_get_boxed (_gtk_css_typed_value_get (data->value));
+
+              pango_font_description_merge (font_desc, font_desc_to_merge, replace);
+            }
+          else if (_gtk_is_css_typed_value_of_type (data->value, G_TYPE_PTR_ARRAY) &&
+                   value->value != NULL)
+            {
+              GPtrArray *array, *array_to_merge;
+              gint i;
+
+              /* Append the array, mainly thought
+               * for the gtk-key-bindings property
+               */
+              array = g_value_get_boxed (_gtk_css_typed_value_get (value->value));
+              array_to_merge = g_value_get_boxed (_gtk_css_typed_value_get (data->value));
+
+              for (i = 0; i < array_to_merge->len; i++)
+                g_ptr_array_add (array, g_ptr_array_index (array_to_merge, i));
+            }
+          else if (replace || value->value == NULL)
+            {
+             _gtk_css_value_unref (value->value);
+             value->value = _gtk_css_value_ref (data->value);
+            }
+        }
+    }
+
+  _gtk_style_provider_private_changed (GTK_STYLE_PROVIDER_PRIVATE (props));
+}
+
+G_GNUC_END_IGNORE_DEPRECATIONS;
diff --git a/gtk/deprecated/gtkstyleproperties.h b/gtk/deprecated/gtkstyleproperties.h
new file mode 100644 (file)
index 0000000..c59c7af
--- /dev/null
@@ -0,0 +1,134 @@
+/* GTK - The GIMP Toolkit
+ * Copyright (C) 2010 Carlos Garnacho <carlosg@gnome.org>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef __GTK_STYLE_PROPERTIES_H__
+#define __GTK_STYLE_PROPERTIES_H__
+
+#if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
+#error "Only <gtk/gtk.h> can be included directly."
+#endif
+
+#include <glib-object.h>
+#include <gdk/gdk.h>
+#include <gtk/gtkenums.h>
+
+G_BEGIN_DECLS
+
+#define GTK_TYPE_STYLE_PROPERTIES         (gtk_style_properties_get_type ())
+#define GTK_STYLE_PROPERTIES(o)           (G_TYPE_CHECK_INSTANCE_CAST ((o), GTK_TYPE_STYLE_PROPERTIES, GtkStyleProperties))
+#define GTK_STYLE_PROPERTIES_CLASS(c)     (G_TYPE_CHECK_CLASS_CAST    ((c), GTK_TYPE_STYLE_PROPERTIES, GtkStylePropertiesClass))
+#define GTK_IS_STYLE_PROPERTIES(o)        (G_TYPE_CHECK_INSTANCE_TYPE ((o), GTK_TYPE_STYLE_PROPERTIES))
+#define GTK_IS_STYLE_PROPERTIES_CLASS(c)  (G_TYPE_CHECK_CLASS_TYPE    ((c), GTK_TYPE_STYLE_PROPERTIES))
+#define GTK_STYLE_PROPERTIES_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS  ((o), GTK_TYPE_STYLE_PROPERTIES, GtkStylePropertiesClass))
+
+typedef struct _GtkStyleProperties GtkStyleProperties;
+typedef struct _GtkStylePropertiesClass GtkStylePropertiesClass;
+typedef struct _GtkStylePropertiesPrivate GtkStylePropertiesPrivate;
+
+typedef struct _GtkSymbolicColor GtkSymbolicColor;
+typedef struct _GtkGradient GtkGradient;
+
+struct _GtkStyleProperties
+{
+  /*< private >*/
+  GObject parent_object;
+  GtkStylePropertiesPrivate *priv;
+};
+
+struct _GtkStylePropertiesClass
+{
+  /*< private >*/
+  GObjectClass parent_class;
+
+  /* Padding for future expansion */
+  void (*_gtk_reserved1) (void);
+  void (*_gtk_reserved2) (void);
+  void (*_gtk_reserved3) (void);
+  void (*_gtk_reserved4) (void);
+};
+
+typedef gboolean (* GtkStylePropertyParser) (const gchar  *string,
+                                             GValue       *value,
+                                             GError      **error);
+
+GDK_DEPRECATED_IN_3_16
+GType gtk_style_properties_get_type (void) G_GNUC_CONST;
+
+/* Next 2 are implemented in gtkcsscustomproperty.c */
+GDK_DEPRECATED_IN_3_8
+void     gtk_style_properties_register_property (GtkStylePropertyParser  parse_func,
+                                                 GParamSpec             *pspec);
+GDK_DEPRECATED_IN_3_8
+gboolean gtk_style_properties_lookup_property   (const gchar             *property_name,
+                                                 GtkStylePropertyParser  *parse_func,
+                                                 GParamSpec             **pspec);
+
+GDK_DEPRECATED_IN_3_16
+GtkStyleProperties * gtk_style_properties_new (void);
+
+GDK_DEPRECATED_IN_3_8
+void               gtk_style_properties_map_color    (GtkStyleProperties *props,
+                                                      const gchar        *name,
+                                                      GtkSymbolicColor   *color);
+GDK_DEPRECATED_IN_3_8
+GtkSymbolicColor * gtk_style_properties_lookup_color (GtkStyleProperties *props,
+                                                      const gchar        *name);
+
+GDK_DEPRECATED_IN_3_16
+void     gtk_style_properties_set_property (GtkStyleProperties *props,
+                                            const gchar        *property,
+                                            GtkStateFlags       state,
+                                            const GValue       *value);
+GDK_DEPRECATED_IN_3_16
+void     gtk_style_properties_set_valist   (GtkStyleProperties *props,
+                                            GtkStateFlags       state,
+                                            va_list             args);
+GDK_DEPRECATED_IN_3_16
+void     gtk_style_properties_set          (GtkStyleProperties *props,
+                                            GtkStateFlags       state,
+                                            ...) G_GNUC_NULL_TERMINATED;
+
+GDK_DEPRECATED_IN_3_16
+gboolean gtk_style_properties_get_property (GtkStyleProperties *props,
+                                            const gchar        *property,
+                                            GtkStateFlags       state,
+                                            GValue             *value);
+GDK_DEPRECATED_IN_3_16
+void     gtk_style_properties_get_valist   (GtkStyleProperties *props,
+                                            GtkStateFlags       state,
+                                            va_list             args);
+GDK_DEPRECATED_IN_3_16
+void     gtk_style_properties_get          (GtkStyleProperties *props,
+                                            GtkStateFlags       state,
+                                            ...) G_GNUC_NULL_TERMINATED;
+
+GDK_DEPRECATED_IN_3_16
+void     gtk_style_properties_unset_property (GtkStyleProperties *props,
+                                              const gchar        *property,
+                                              GtkStateFlags       state);
+
+GDK_DEPRECATED_IN_3_16
+void     gtk_style_properties_clear          (GtkStyleProperties  *props);
+
+GDK_DEPRECATED_IN_3_16
+void     gtk_style_properties_merge          (GtkStyleProperties       *props,
+                                              const GtkStyleProperties *props_to_merge,
+                                              gboolean                  replace);
+
+G_END_DECLS
+
+#endif /* __GTK_STYLE_PROPERTIES_H__ */
diff --git a/gtk/deprecated/gtkstylepropertiesprivate.h b/gtk/deprecated/gtkstylepropertiesprivate.h
new file mode 100644 (file)
index 0000000..77268d9
--- /dev/null
@@ -0,0 +1,34 @@
+/* GTK - The GIMP Toolkit
+ * Copyright (C) 2010 Carlos Garnacho <carlosg@gnome.org>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef __GTK_STYLE_PROPERTIES_PRIVATE_H__
+#define __GTK_STYLE_PROPERTIES_PRIVATE_H__
+
+#include "gtkstyleproperties.h"
+#include "gtkcssstylepropertyprivate.h"
+#include "gtkstylecontextprivate.h"
+
+G_BEGIN_DECLS
+
+void           _gtk_style_properties_set_property_by_property (GtkStyleProperties      *props,
+                                                               GtkCssStyleProperty     *property,
+                                                               GtkStateFlags            state,
+                                                               GtkCssValue             *value);
+
+G_END_DECLS
+
+#endif /* __GTK_STYLE_PROPERTIES_PRIVATE_H__ */
index 860704faf2297285813f5c665ef4ac789b192d12..8beded60db03229525b4b52ef7c2ee34f5cfe8a5 100644 (file)
@@ -23,7 +23,7 @@
 #endif
 
 #include <gdk/gdk.h>
-#include <gtk/gtkstyleproperties.h>
+#include <gtk/deprecated/gtkstyleproperties.h>
 
 G_BEGIN_DECLS
 
index 469504fe437736c1fe0b1314f442704e47fb839f..e04fc1c5396fc2b0fb78371cc2bbea1494b30b4f 100644 (file)
@@ -27,7 +27,7 @@
 
 #include <gtk/gtkborder.h>
 #include <gtk/gtkenums.h>
-#include <gtk/gtkstyleproperties.h>
+#include <gtk/deprecated/gtkstyleproperties.h>
 #include <gtk/gtktypes.h>
 
 G_BEGIN_DECLS
index 937a073d0b188562b315e052bf0de55b422ef73d..5955dd90bba37010efa60fde5a3835341b44fab9 100644 (file)
--- a/gtk/gtk.h
+++ b/gtk/gtk.h
 #include <gtk/gtkstackswitcher.h>
 #include <gtk/gtkstatusbar.h>
 #include <gtk/gtkstylecontext.h>
-#include <gtk/gtkstyleproperties.h>
 #include <gtk/gtkstyleprovider.h>
 #include <gtk/gtkswitch.h>
 #include <gtk/gtktextattributes.h>
 #include <gtk/deprecated/gtkstatusicon.h>
 #include <gtk/deprecated/gtkstock.h>
 #include <gtk/deprecated/gtkstyle.h>
+#include <gtk/deprecated/gtkstyleproperties.h>
 #include <gtk/deprecated/gtksymboliccolor.h>
 #include <gtk/deprecated/gtktable.h>
 #include <gtk/deprecated/gtktearoffmenuitem.h>
diff --git a/gtk/gtkstyleproperties.c b/gtk/gtkstyleproperties.c
deleted file mode 100644 (file)
index f61f7a2..0000000
+++ /dev/null
@@ -1,956 +0,0 @@
-/* GTK - The GIMP Toolkit
- * Copyright (C) 2010 Carlos Garnacho <carlosg@gnome.org>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library. If not, see <http://www.gnu.org/licenses/>.
- */
-
-#include "config.h"
-
-#include "gtkstylepropertiesprivate.h"
-
-#include <stdlib.h>
-#include <gobject/gvaluecollector.h>
-#include <cairo-gobject.h>
-
-#include "gtkstyleprovider.h"
-#include "gtkcssshorthandpropertyprivate.h"
-#include "gtkcsstypedvalueprivate.h"
-#include "gtkcsstypesprivate.h"
-#include "gtkborderimageprivate.h"
-
-#include "gtkprivatetypebuiltins.h"
-#include "gtkstylepropertyprivate.h"
-#include "gtkstyleproviderprivate.h"
-#include "gtkintl.h"
-#include "gtkwin32themeprivate.h"
-
-#include "deprecated/gtkthemingengine.h"
-#include "deprecated/gtkgradient.h"
-#include "deprecated/gtksymboliccolorprivate.h"
-
-G_GNUC_BEGIN_IGNORE_DEPRECATIONS;
-
-/**
- * SECTION:gtkstyleproperties
- * @Short_description: Store for style property information
- * @Title: GtkStyleProperties
- *
- * GtkStyleProperties provides the storage for style information
- * that is used by #GtkStyleContext and other #GtkStyleProvider
- * implementations.
- *
- * Before style properties can be stored in GtkStyleProperties, they
- * must be registered with gtk_style_properties_register_property().
- *
- * Unless you are writing a #GtkStyleProvider implementation, you
- * are unlikely to use this API directly, as gtk_style_context_get()
- * and its variants are the preferred way to access styling information
- * from widget implementations and theming engine implementations
- * should use the APIs provided by #GtkThemingEngine instead.
- *
- * #GtkStyleProperties has been deprecated in GTK 3.16. The CSS
- * machinery does not use it anymore and all users of this object
- * have been deprecated.
- */
-
-typedef struct PropertyData PropertyData;
-typedef struct ValueData ValueData;
-
-struct ValueData
-{
-  GtkStateFlags state;
-  GtkCssValue *value;
-};
-
-struct PropertyData
-{
-  GArray *values;
-};
-
-struct _GtkStylePropertiesPrivate
-{
-  GHashTable *color_map;
-  GHashTable *properties;
-};
-
-static void gtk_style_properties_provider_init         (GtkStyleProviderIface            *iface);
-static void gtk_style_properties_provider_private_init (GtkStyleProviderPrivateInterface *iface);
-static void gtk_style_properties_finalize              (GObject                          *object);
-
-
-G_DEFINE_TYPE_WITH_CODE (GtkStyleProperties, gtk_style_properties, G_TYPE_OBJECT,
-                         G_ADD_PRIVATE (GtkStyleProperties)
-                         G_IMPLEMENT_INTERFACE (GTK_TYPE_STYLE_PROVIDER,
-                                                gtk_style_properties_provider_init)
-                         G_IMPLEMENT_INTERFACE (GTK_TYPE_STYLE_PROVIDER_PRIVATE,
-                                                gtk_style_properties_provider_private_init));
-
-static void
-gtk_style_properties_class_init (GtkStylePropertiesClass *klass)
-{
-  GObjectClass *object_class = G_OBJECT_CLASS (klass);
-
-  object_class->finalize = gtk_style_properties_finalize;
-}
-
-static PropertyData *
-property_data_new (void)
-{
-  PropertyData *data;
-
-  data = g_slice_new0 (PropertyData);
-  data->values = g_array_new (FALSE, FALSE, sizeof (ValueData));
-
-  return data;
-}
-
-static void
-property_data_remove_values (PropertyData *data)
-{
-  guint i;
-
-  for (i = 0; i < data->values->len; i++)
-    {
-      ValueData *value_data;
-
-      value_data = &g_array_index (data->values, ValueData, i);
-
-      _gtk_css_value_unref (value_data->value);
-      value_data->value = NULL;
-    }
-
-  if (data->values->len > 0)
-    g_array_remove_range (data->values, 0, data->values->len);
-}
-
-static void
-property_data_free (PropertyData *data)
-{
-  property_data_remove_values (data);
-  g_array_free (data->values, TRUE);
-  g_slice_free (PropertyData, data);
-}
-
-static gboolean
-property_data_find_position (PropertyData  *data,
-                             GtkStateFlags  state,
-                             guint         *pos)
-{
-  gint min, max, mid;
-  gboolean found = FALSE;
-  guint position;
-
-  if (pos)
-    *pos = 0;
-
-  if (data->values->len == 0)
-    return FALSE;
-
-  /* Find position for the given state, or the position where
-   * it would be if not found, the array is ordered by the
-   * state flags.
-   */
-  min = 0;
-  max = data->values->len - 1;
-
-  do
-    {
-      ValueData *value_data;
-
-      mid = (min + max) / 2;
-      value_data = &g_array_index (data->values, ValueData, mid);
-
-      if (value_data->state == state)
-        {
-          found = TRUE;
-          position = mid;
-        }
-      else if (value_data->state < state)
-          position = min = mid + 1;
-      else
-        {
-          max = mid - 1;
-          position = mid;
-        }
-    }
-  while (!found && min <= max);
-
-  if (pos)
-    *pos = position;
-
-  return found;
-}
-
-static ValueData *
-property_data_get_value (PropertyData  *data,
-                         GtkStateFlags  state)
-{
-  guint pos;
-
-  if (!property_data_find_position (data, state, &pos))
-    {
-      ValueData new = { 0 };
-
-      new.state = state;
-      g_array_insert_val (data->values, pos, new);
-    }
-
-  return &g_array_index (data->values, ValueData, pos);
-}
-
-static GtkCssValue *
-property_data_match_state (PropertyData  *data,
-                           GtkStateFlags  state)
-{
-  guint pos;
-  gint i;
-
-  if (property_data_find_position (data, state, &pos))
-    {
-      ValueData *val_data;
-
-      /* Exact match */
-      val_data = &g_array_index (data->values, ValueData, pos);
-      return val_data->value;
-    }
-
-  if (pos >= data->values->len)
-    pos = data->values->len - 1;
-
-  /* No exact match, go downwards the list to find
-   * the closest match to the given state flags, as
-   * a side effect, there is an implicit precedence
-   * of higher flags over the smaller ones.
-   */
-  for (i = pos; i >= 0; i--)
-    {
-      ValueData *val_data;
-
-      val_data = &g_array_index (data->values, ValueData, i);
-
-       /* Check whether any of the requested
-        * flags are set, and no other flags are.
-        *
-        * Also, no flags acts as a wildcard, such
-        * value should be always in the first position
-        * in the array (if present) anyways.
-        */
-      if (val_data->state == 0 ||
-          ((val_data->state & state) != 0 &&
-           (val_data->state & ~state) == 0))
-        return val_data->value;
-    }
-
-  return NULL;
-}
-
-static void
-gtk_style_properties_init (GtkStyleProperties *props)
-{
-  props->priv = gtk_style_properties_get_instance_private (props);
-  props->priv->properties = g_hash_table_new_full (NULL, NULL, NULL,
-                                                   (GDestroyNotify) property_data_free);
-}
-
-static void
-gtk_style_properties_finalize (GObject *object)
-{
-  GtkStylePropertiesPrivate *priv;
-  GtkStyleProperties *props;
-
-  props = GTK_STYLE_PROPERTIES (object);
-  priv = props->priv;
-  g_hash_table_destroy (priv->properties);
-
-  if (priv->color_map)
-    g_hash_table_destroy (priv->color_map);
-
-  G_OBJECT_CLASS (gtk_style_properties_parent_class)->finalize (object);
-}
-
-static void
-gtk_style_properties_provider_init (GtkStyleProviderIface *iface)
-{
-}
-
-static GtkCssValue *
-gtk_style_properties_provider_get_color (GtkStyleProviderPrivate *provider,
-                                         const char              *name)
-{
-  GtkSymbolicColor *symbolic;
-
-  symbolic = gtk_style_properties_lookup_color (GTK_STYLE_PROPERTIES (provider), name);
-  if (symbolic == NULL)
-    return NULL;
-
-  return _gtk_symbolic_color_get_css_value (symbolic);
-}
-
-static void
-gtk_style_properties_provider_lookup (GtkStyleProviderPrivate *provider,
-                                      const GtkCssMatcher     *matcher,
-                                      GtkCssLookup            *lookup)
-{
-  GtkStyleProperties *props;
-  GtkStylePropertiesPrivate *priv;
-  GHashTableIter iter;
-  gpointer key, value;
-
-  props = GTK_STYLE_PROPERTIES (provider);
-  priv = props->priv;
-
-  /* Merge symbolic style properties */
-  g_hash_table_iter_init (&iter, priv->properties);
-
-  while (g_hash_table_iter_next (&iter, &key, &value))
-    {
-      GtkCssStyleProperty *prop = key;
-      PropertyData *data = value;
-      GtkCssValue *value;
-      guint id;
-
-      id = _gtk_css_style_property_get_id (prop);
-
-      if (!_gtk_css_lookup_is_missing (lookup, id))
-          continue;
-
-      value = property_data_match_state (data, _gtk_css_matcher_get_state (matcher));
-      if (value == NULL)
-        continue;
-
-      _gtk_css_lookup_set (lookup, id, NULL, value);
-    }
-}
-
-static GtkCssChange
-gtk_style_properties_provider_get_change (GtkStyleProviderPrivate *provider,
-                                          const GtkCssMatcher     *matcher)
-{
-  return GTK_CSS_CHANGE_STATE;
-}
-
-static void
-gtk_style_properties_provider_private_init (GtkStyleProviderPrivateInterface *iface)
-{
-  iface->get_color = gtk_style_properties_provider_get_color;
-  iface->lookup = gtk_style_properties_provider_lookup;
-  iface->get_change = gtk_style_properties_provider_get_change;
-}
-
-/* GtkStyleProperties methods */
-
-/**
- * gtk_style_properties_new:
- *
- * Returns a newly created #GtkStyleProperties
- *
- * Returns: a new #GtkStyleProperties
- *
- * Deprecated: 3.16: #GtkStyleProperties are deprecated.
- **/
-GtkStyleProperties *
-gtk_style_properties_new (void)
-{
-  return g_object_new (GTK_TYPE_STYLE_PROPERTIES, NULL);
-}
-
-/**
- * gtk_style_properties_map_color:
- * @props: a #GtkStyleProperties
- * @name: color name
- * @color: #GtkSymbolicColor to map @name to
- *
- * Maps @color so it can be referenced by @name. See
- * gtk_style_properties_lookup_color()
- *
- * Since: 3.0
- *
- * Deprecated: 3.8: #GtkSymbolicColor is deprecated.
- **/
-void
-gtk_style_properties_map_color (GtkStyleProperties *props,
-                                const gchar        *name,
-                                GtkSymbolicColor   *color)
-{
-  GtkStylePropertiesPrivate *priv;
-
-  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
-  g_return_if_fail (name != NULL);
-  g_return_if_fail (color != NULL);
-
-  priv = props->priv;
-
-  if (G_UNLIKELY (!priv->color_map))
-    priv->color_map = g_hash_table_new_full (g_str_hash,
-                                             g_str_equal,
-                                             (GDestroyNotify) g_free,
-                                             (GDestroyNotify) gtk_symbolic_color_unref);
-
-  g_hash_table_replace (priv->color_map,
-                        g_strdup (name),
-                        gtk_symbolic_color_ref (color));
-
-  _gtk_style_provider_private_changed (GTK_STYLE_PROVIDER_PRIVATE (props));
-}
-
-/**
- * gtk_style_properties_lookup_color:
- * @props: a #GtkStyleProperties
- * @name: color name to lookup
- *
- * Returns the symbolic color that is mapped
- * to @name.
- *
- * Returns: (transfer none): The mapped color
- *
- * Since: 3.0
- *
- * Deprecated: 3.8: #GtkSymbolicColor is deprecated.
- **/
-GtkSymbolicColor *
-gtk_style_properties_lookup_color (GtkStyleProperties *props,
-                                   const gchar        *name)
-{
-  GtkStylePropertiesPrivate *priv;
-
-  g_return_val_if_fail (GTK_IS_STYLE_PROPERTIES (props), NULL);
-  g_return_val_if_fail (name != NULL, NULL);
-
-  priv = props->priv;
-
-  if (!priv->color_map)
-    return NULL;
-
-  return g_hash_table_lookup (priv->color_map, name);
-}
-
-void
-_gtk_style_properties_set_property_by_property (GtkStyleProperties  *props,
-                                                GtkCssStyleProperty *style_prop,
-                                                GtkStateFlags        state,
-                                                GtkCssValue         *value)
-{
-  GtkStylePropertiesPrivate *priv;
-  PropertyData *prop;
-  ValueData *val;
-
-  priv = props->priv;
-  prop = g_hash_table_lookup (priv->properties, style_prop);
-
-  if (!prop)
-    {
-      prop = property_data_new ();
-      g_hash_table_insert (priv->properties, (gpointer) style_prop, prop);
-    }
-
-  val = property_data_get_value (prop, state);
-
-  _gtk_css_value_unref (val->value);
-  val->value = _gtk_css_value_ref (value);
-
-  _gtk_style_provider_private_changed (GTK_STYLE_PROVIDER_PRIVATE (props));
-}
-
-/**
- * gtk_style_properties_set_property:
- * @props: a #GtkStyleProperties
- * @property: styling property to set
- * @state: state to set the value for
- * @value: new value for the property
- *
- * Sets a styling property in @props.
- *
- * Since: 3.0
- *
- * Deprecated: 3.16: #GtkStyleProperties are deprecated.
- **/
-void
-gtk_style_properties_set_property (GtkStyleProperties *props,
-                                   const gchar        *property,
-                                   GtkStateFlags       state,
-                                   const GValue       *value)
-{
-  GtkStyleProperty *node;
-
-  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
-  g_return_if_fail (property != NULL);
-  g_return_if_fail (value != NULL);
-
-  node = _gtk_style_property_lookup (property);
-
-  if (!node)
-    {
-      g_warning ("Style property \"%s\" is not registered", property);
-      return;
-    }
-  if (_gtk_style_property_get_value_type (node) == G_TYPE_NONE)
-    {
-      g_warning ("Style property \"%s\" is not settable", property);
-      return;
-    }
-  
-  _gtk_style_property_assign (node, props, state, value);
-}
-
-/**
- * gtk_style_properties_set_valist:
- * @props: a #GtkStyleProperties
- * @state: state to set the values for
- * @args: va_list of property name/value pairs, followed by %NULL
- *
- * Sets several style properties on @props.
- *
- * Since: 3.0
- *
- * Deprecated: 3.16: #GtkStyleProperties are deprecated.
- **/
-void
-gtk_style_properties_set_valist (GtkStyleProperties *props,
-                                 GtkStateFlags       state,
-                                 va_list             args)
-{
-  const gchar *property_name;
-
-  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
-
-  property_name = va_arg (args, const gchar *);
-
-  while (property_name)
-    {
-      GtkStyleProperty *node;
-      gchar *error = NULL;
-      GType val_type;
-      GValue val = G_VALUE_INIT;
-
-      node = _gtk_style_property_lookup (property_name);
-
-      if (!node)
-        {
-          g_warning ("Style property \"%s\" is not registered", property_name);
-          break;
-        }
-
-      val_type = _gtk_style_property_get_value_type (node);
-      if (val_type == G_TYPE_NONE)
-        {
-          g_warning ("Style property \"%s\" is not settable", property_name);
-          break;
-        }
-
-      G_VALUE_COLLECT_INIT (&val, _gtk_style_property_get_value_type (node),
-                            args, 0, &error);
-      if (error)
-        {
-          g_warning ("Could not set style property \"%s\": %s", property_name, error);
-          g_value_unset (&val);
-          g_free (error);
-          break;
-        }
-
-      _gtk_style_property_assign (node, props, state, &val);
-      g_value_unset (&val);
-
-      property_name = va_arg (args, const gchar *);
-    }
-}
-
-/**
- * gtk_style_properties_set:
- * @props: a #GtkStyleProperties
- * @state: state to set the values for
- * @...: property name/value pairs, followed by %NULL
- *
- * Sets several style properties on @props.
- *
- * Since: 3.0
- *
- * Deprecated: 3.16: #GtkStyleProperties are deprecated.
- **/
-void
-gtk_style_properties_set (GtkStyleProperties *props,
-                          GtkStateFlags       state,
-                          ...)
-{
-  va_list args;
-
-  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
-
-  va_start (args, state);
-  gtk_style_properties_set_valist (props, state, args);
-  va_end (args);
-}
-
-typedef struct {
-  GtkStyleProperties *props;
-  GtkStateFlags       state;
-} StyleQueryData;
-
-static GtkCssValue *
-style_query_func (guint    id,
-                  gpointer data)
-{
-  StyleQueryData *query = data;
-  PropertyData *prop;
-
-  prop = g_hash_table_lookup (query->props->priv->properties,
-                              _gtk_css_style_property_lookup_by_id (id));
-  if (prop == NULL)
-    return NULL;
-
-  return property_data_match_state (prop, query->state);
-}
-
-/**
- * gtk_style_properties_get_property:
- * @props: a #GtkStyleProperties
- * @property: style property name
- * @state: state to retrieve the property value for
- * @value: (out) (transfer full):  return location for the style property value.
- *
- * Gets a style property from @props for the given state. When done with @value,
- * g_value_unset() needs to be called to free any allocated memory.
- *
- * Returns: %TRUE if the property exists in @props, %FALSE otherwise
- *
- * Since: 3.0
- *
- * Deprecated: 3.16: #GtkStyleProperties are deprecated.
- **/
-gboolean
-gtk_style_properties_get_property (GtkStyleProperties *props,
-                                   const gchar        *property,
-                                   GtkStateFlags       state,
-                                   GValue             *value)
-{
-  StyleQueryData query = { props, state };
-  GtkStyleProperty *node;
-
-  g_return_val_if_fail (GTK_IS_STYLE_PROPERTIES (props), FALSE);
-  g_return_val_if_fail (property != NULL, FALSE);
-  g_return_val_if_fail (value != NULL, FALSE);
-
-  node = _gtk_style_property_lookup (property);
-  if (!node)
-    {
-      g_warning ("Style property \"%s\" is not registered", property);
-      return FALSE;
-    }
-  if (_gtk_style_property_get_value_type (node) == G_TYPE_NONE)
-    {
-      g_warning ("Style property \"%s\" is not gettable", property);
-      return FALSE;
-    }
-
-  _gtk_style_property_query (node,
-                             value,
-                             style_query_func,
-                             &query);
-
-  return TRUE;
-}
-
-/**
- * gtk_style_properties_get_valist:
- * @props: a #GtkStyleProperties
- * @state: state to retrieve the property values for
- * @args: va_list of property name/return location pairs, followed by %NULL
- *
- * Retrieves several style property values from @props for a given state.
- *
- * Since: 3.0
- *
- * Deprecated: 3.16: #GtkStyleProperties are deprecated.
- **/
-void
-gtk_style_properties_get_valist (GtkStyleProperties *props,
-                                 GtkStateFlags       state,
-                                 va_list             args)
-{
-  const gchar *property_name;
-
-  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
-
-  property_name = va_arg (args, const gchar *);
-
-  while (property_name)
-    {
-      gchar *error = NULL;
-      GValue value = G_VALUE_INIT;
-
-      if (!gtk_style_properties_get_property (props,
-                                             property_name,
-                                             state,
-                                             &value))
-       break;
-
-      G_VALUE_LCOPY (&value, args, 0, &error);
-      g_value_unset (&value);
-
-      if (error)
-        {
-          g_warning ("Could not get style property \"%s\": %s", property_name, error);
-          g_free (error);
-          break;
-        }
-
-      property_name = va_arg (args, const gchar *);
-    }
-}
-
-/**
- * gtk_style_properties_get:
- * @props: a #GtkStyleProperties
- * @state: state to retrieve the property values for
- * @...: property name /return value pairs, followed by %NULL
- *
- * Retrieves several style property values from @props for a
- * given state.
- *
- * Since: 3.0
- *
- * Deprecated: 3.16: #GtkStyleProperties are deprecated.
- **/
-void
-gtk_style_properties_get (GtkStyleProperties *props,
-                          GtkStateFlags       state,
-                          ...)
-{
-  va_list args;
-
-  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
-
-  va_start (args, state);
-  gtk_style_properties_get_valist (props, state, args);
-  va_end (args);
-}
-
-/**
- * gtk_style_properties_unset_property:
- * @props: a #GtkStyleProperties
- * @property: property to unset
- * @state: state to unset
- *
- * Unsets a style property in @props.
- *
- * Since: 3.0
- *
- * Deprecated: 3.16: #GtkStyleProperties are deprecated.
- **/
-void
-gtk_style_properties_unset_property (GtkStyleProperties *props,
-                                     const gchar        *property,
-                                     GtkStateFlags       state)
-{
-  GtkStylePropertiesPrivate *priv;
-  GtkStyleProperty *node;
-  PropertyData *prop;
-  guint pos;
-
-  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
-  g_return_if_fail (property != NULL);
-
-  node = _gtk_style_property_lookup (property);
-
-  if (!node)
-    {
-      g_warning ("Style property \"%s\" is not registered", property);
-      return;
-    }
-  if (_gtk_style_property_get_value_type (node) == G_TYPE_NONE)
-    {
-      g_warning ("Style property \"%s\" is not settable", property);
-      return;
-    }
-
-  if (GTK_IS_CSS_SHORTHAND_PROPERTY (node))
-    {
-      GtkCssShorthandProperty *shorthand = GTK_CSS_SHORTHAND_PROPERTY (node);
-
-      for (pos = 0; pos < _gtk_css_shorthand_property_get_n_subproperties (shorthand); pos++)
-        {
-          GtkCssStyleProperty *sub = _gtk_css_shorthand_property_get_subproperty (shorthand, pos);
-          gtk_style_properties_unset_property (props,
-                                               _gtk_style_property_get_name (GTK_STYLE_PROPERTY (sub)),
-                                               state);
-        }
-      return;
-    }
-
-  priv = props->priv;
-  prop = g_hash_table_lookup (priv->properties, node);
-
-  if (!prop)
-    return;
-
-  if (property_data_find_position (prop, state, &pos))
-    {
-      ValueData *data;
-
-      data = &g_array_index (prop->values, ValueData, pos);
-
-      _gtk_css_value_unref (data->value);
-      data->value = NULL;
-
-      g_array_remove_index (prop->values, pos);
-
-      _gtk_style_provider_private_changed (GTK_STYLE_PROVIDER_PRIVATE (props));
-    }
-}
-
-/**
- * gtk_style_properties_clear:
- * @props: a #GtkStyleProperties
- *
- * Clears all style information from @props.
- *
- * Deprecated: 3.16: #GtkStyleProperties are deprecated.
- **/
-void
-gtk_style_properties_clear (GtkStyleProperties *props)
-{
-  GtkStylePropertiesPrivate *priv;
-
-  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
-
-  priv = props->priv;
-  g_hash_table_remove_all (priv->properties);
-
-  _gtk_style_provider_private_changed (GTK_STYLE_PROVIDER_PRIVATE (props));
-}
-
-/**
- * gtk_style_properties_merge:
- * @props: a #GtkStyleProperties
- * @props_to_merge: a second #GtkStyleProperties
- * @replace: whether to replace values or not
- *
- * Merges into @props all the style information contained
- * in @props_to_merge. If @replace is %TRUE, the values
- * will be overwritten, if it is %FALSE, the older values
- * will prevail.
- *
- * Since: 3.0
- *
- * Deprecated: 3.16: #GtkStyleProperties are deprecated.
- **/
-void
-gtk_style_properties_merge (GtkStyleProperties       *props,
-                            const GtkStyleProperties *props_to_merge,
-                            gboolean                  replace)
-{
-  GtkStylePropertiesPrivate *priv, *priv_to_merge;
-  GHashTableIter iter;
-  gpointer key, value;
-
-  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
-  g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props_to_merge));
-
-  priv = props->priv;
-  priv_to_merge = props_to_merge->priv;
-
-  /* Merge symbolic color map */
-  if (priv_to_merge->color_map)
-    {
-      g_hash_table_iter_init (&iter, priv_to_merge->color_map);
-
-      while (g_hash_table_iter_next (&iter, &key, &value))
-        {
-          const gchar *name;
-          GtkSymbolicColor *color;
-
-          name = key;
-          color = value;
-
-          if (!replace &&
-              g_hash_table_lookup (priv->color_map, name))
-            continue;
-
-          gtk_style_properties_map_color (props, name, color);
-        }
-    }
-
-  /* Merge symbolic style properties */
-  g_hash_table_iter_init (&iter, priv_to_merge->properties);
-
-  while (g_hash_table_iter_next (&iter, &key, &value))
-    {
-      PropertyData *prop_to_merge = value;
-      PropertyData *prop;
-      guint i;
-
-      prop = g_hash_table_lookup (priv->properties, key);
-
-      if (!prop)
-        {
-          prop = property_data_new ();
-          g_hash_table_insert (priv->properties, key, prop);
-        }
-
-      for (i = 0; i < prop_to_merge->values->len; i++)
-        {
-          ValueData *data;
-          ValueData *value;
-
-          data = &g_array_index (prop_to_merge->values, ValueData, i);
-
-          if (replace && data->state == GTK_STATE_FLAG_NORMAL &&
-              _gtk_is_css_typed_value_of_type (data->value, PANGO_TYPE_FONT_DESCRIPTION))
-            {
-              /* Let normal state override all states
-               * previously set in the original set
-               */
-              property_data_remove_values (prop);
-            }
-
-          value = property_data_get_value (prop, data->state);
-
-          if (_gtk_is_css_typed_value_of_type (data->value, PANGO_TYPE_FONT_DESCRIPTION) &&
-              value->value != NULL)
-            {
-              PangoFontDescription *font_desc;
-              PangoFontDescription *font_desc_to_merge;
-
-              /* Handle merging of font descriptions */
-              font_desc = g_value_get_boxed (_gtk_css_typed_value_get (value->value));
-              font_desc_to_merge = g_value_get_boxed (_gtk_css_typed_value_get (data->value));
-
-              pango_font_description_merge (font_desc, font_desc_to_merge, replace);
-            }
-          else if (_gtk_is_css_typed_value_of_type (data->value, G_TYPE_PTR_ARRAY) &&
-                   value->value != NULL)
-            {
-              GPtrArray *array, *array_to_merge;
-              gint i;
-
-              /* Append the array, mainly thought
-               * for the gtk-key-bindings property
-               */
-              array = g_value_get_boxed (_gtk_css_typed_value_get (value->value));
-              array_to_merge = g_value_get_boxed (_gtk_css_typed_value_get (data->value));
-
-              for (i = 0; i < array_to_merge->len; i++)
-                g_ptr_array_add (array, g_ptr_array_index (array_to_merge, i));
-            }
-          else if (replace || value->value == NULL)
-            {
-             _gtk_css_value_unref (value->value);
-             value->value = _gtk_css_value_ref (data->value);
-            }
-        }
-    }
-
-  _gtk_style_provider_private_changed (GTK_STYLE_PROVIDER_PRIVATE (props));
-}
-
-G_GNUC_END_IGNORE_DEPRECATIONS;
diff --git a/gtk/gtkstyleproperties.h b/gtk/gtkstyleproperties.h
deleted file mode 100644 (file)
index c59c7af..0000000
+++ /dev/null
@@ -1,134 +0,0 @@
-/* GTK - The GIMP Toolkit
- * Copyright (C) 2010 Carlos Garnacho <carlosg@gnome.org>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library. If not, see <http://www.gnu.org/licenses/>.
- */
-
-#ifndef __GTK_STYLE_PROPERTIES_H__
-#define __GTK_STYLE_PROPERTIES_H__
-
-#if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
-#error "Only <gtk/gtk.h> can be included directly."
-#endif
-
-#include <glib-object.h>
-#include <gdk/gdk.h>
-#include <gtk/gtkenums.h>
-
-G_BEGIN_DECLS
-
-#define GTK_TYPE_STYLE_PROPERTIES         (gtk_style_properties_get_type ())
-#define GTK_STYLE_PROPERTIES(o)           (G_TYPE_CHECK_INSTANCE_CAST ((o), GTK_TYPE_STYLE_PROPERTIES, GtkStyleProperties))
-#define GTK_STYLE_PROPERTIES_CLASS(c)     (G_TYPE_CHECK_CLASS_CAST    ((c), GTK_TYPE_STYLE_PROPERTIES, GtkStylePropertiesClass))
-#define GTK_IS_STYLE_PROPERTIES(o)        (G_TYPE_CHECK_INSTANCE_TYPE ((o), GTK_TYPE_STYLE_PROPERTIES))
-#define GTK_IS_STYLE_PROPERTIES_CLASS(c)  (G_TYPE_CHECK_CLASS_TYPE    ((c), GTK_TYPE_STYLE_PROPERTIES))
-#define GTK_STYLE_PROPERTIES_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS  ((o), GTK_TYPE_STYLE_PROPERTIES, GtkStylePropertiesClass))
-
-typedef struct _GtkStyleProperties GtkStyleProperties;
-typedef struct _GtkStylePropertiesClass GtkStylePropertiesClass;
-typedef struct _GtkStylePropertiesPrivate GtkStylePropertiesPrivate;
-
-typedef struct _GtkSymbolicColor GtkSymbolicColor;
-typedef struct _GtkGradient GtkGradient;
-
-struct _GtkStyleProperties
-{
-  /*< private >*/
-  GObject parent_object;
-  GtkStylePropertiesPrivate *priv;
-};
-
-struct _GtkStylePropertiesClass
-{
-  /*< private >*/
-  GObjectClass parent_class;
-
-  /* Padding for future expansion */
-  void (*_gtk_reserved1) (void);
-  void (*_gtk_reserved2) (void);
-  void (*_gtk_reserved3) (void);
-  void (*_gtk_reserved4) (void);
-};
-
-typedef gboolean (* GtkStylePropertyParser) (const gchar  *string,
-                                             GValue       *value,
-                                             GError      **error);
-
-GDK_DEPRECATED_IN_3_16
-GType gtk_style_properties_get_type (void) G_GNUC_CONST;
-
-/* Next 2 are implemented in gtkcsscustomproperty.c */
-GDK_DEPRECATED_IN_3_8
-void     gtk_style_properties_register_property (GtkStylePropertyParser  parse_func,
-                                                 GParamSpec             *pspec);
-GDK_DEPRECATED_IN_3_8
-gboolean gtk_style_properties_lookup_property   (const gchar             *property_name,
-                                                 GtkStylePropertyParser  *parse_func,
-                                                 GParamSpec             **pspec);
-
-GDK_DEPRECATED_IN_3_16
-GtkStyleProperties * gtk_style_properties_new (void);
-
-GDK_DEPRECATED_IN_3_8
-void               gtk_style_properties_map_color    (GtkStyleProperties *props,
-                                                      const gchar        *name,
-                                                      GtkSymbolicColor   *color);
-GDK_DEPRECATED_IN_3_8
-GtkSymbolicColor * gtk_style_properties_lookup_color (GtkStyleProperties *props,
-                                                      const gchar        *name);
-
-GDK_DEPRECATED_IN_3_16
-void     gtk_style_properties_set_property (GtkStyleProperties *props,
-                                            const gchar        *property,
-                                            GtkStateFlags       state,
-                                            const GValue       *value);
-GDK_DEPRECATED_IN_3_16
-void     gtk_style_properties_set_valist   (GtkStyleProperties *props,
-                                            GtkStateFlags       state,
-                                            va_list             args);
-GDK_DEPRECATED_IN_3_16
-void     gtk_style_properties_set          (GtkStyleProperties *props,
-                                            GtkStateFlags       state,
-                                            ...) G_GNUC_NULL_TERMINATED;
-
-GDK_DEPRECATED_IN_3_16
-gboolean gtk_style_properties_get_property (GtkStyleProperties *props,
-                                            const gchar        *property,
-                                            GtkStateFlags       state,
-                                            GValue             *value);
-GDK_DEPRECATED_IN_3_16
-void     gtk_style_properties_get_valist   (GtkStyleProperties *props,
-                                            GtkStateFlags       state,
-                                            va_list             args);
-GDK_DEPRECATED_IN_3_16
-void     gtk_style_properties_get          (GtkStyleProperties *props,
-                                            GtkStateFlags       state,
-                                            ...) G_GNUC_NULL_TERMINATED;
-
-GDK_DEPRECATED_IN_3_16
-void     gtk_style_properties_unset_property (GtkStyleProperties *props,
-                                              const gchar        *property,
-                                              GtkStateFlags       state);
-
-GDK_DEPRECATED_IN_3_16
-void     gtk_style_properties_clear          (GtkStyleProperties  *props);
-
-GDK_DEPRECATED_IN_3_16
-void     gtk_style_properties_merge          (GtkStyleProperties       *props,
-                                              const GtkStyleProperties *props_to_merge,
-                                              gboolean                  replace);
-
-G_END_DECLS
-
-#endif /* __GTK_STYLE_PROPERTIES_H__ */
diff --git a/gtk/gtkstylepropertiesprivate.h b/gtk/gtkstylepropertiesprivate.h
deleted file mode 100644 (file)
index 77268d9..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-/* GTK - The GIMP Toolkit
- * Copyright (C) 2010 Carlos Garnacho <carlosg@gnome.org>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library. If not, see <http://www.gnu.org/licenses/>.
- */
-
-#ifndef __GTK_STYLE_PROPERTIES_PRIVATE_H__
-#define __GTK_STYLE_PROPERTIES_PRIVATE_H__
-
-#include "gtkstyleproperties.h"
-#include "gtkcssstylepropertyprivate.h"
-#include "gtkstylecontextprivate.h"
-
-G_BEGIN_DECLS
-
-void           _gtk_style_properties_set_property_by_property (GtkStyleProperties      *props,
-                                                               GtkCssStyleProperty     *property,
-                                                               GtkStateFlags            state,
-                                                               GtkCssValue             *value);
-
-G_END_DECLS
-
-#endif /* __GTK_STYLE_PROPERTIES_PRIVATE_H__ */
index a33ce4345ae6530762a20f2589d07b027e4216c2..cbfd9df2a2ca61430533814a996686fcca0d985d 100644 (file)
@@ -25,7 +25,7 @@
 #include <glib-object.h>
 #include <gtk/gtkenums.h>
 #include <gtk/deprecated/gtkiconfactory.h>
-#include <gtk/gtkstyleproperties.h>
+#include <gtk/deprecated/gtkstyleproperties.h>
 #include <gtk/gtktypes.h>
 
 G_BEGIN_DECLS